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EDITORS COMMENTS . . ے‎ 2 2 2 2 ^ IE 


First I would like to thank Dave Boyce, Dave Mitchell and 
Bob Kitch who submitted their articles on rape and disk. It 


greatly reduces the risk of errors creeping in. Thanks fellas. 


Some promised articles had to be held over vU next issue. 


SNOOPY CALENDAR PART 1 by Dave Boyce :- E Page 4—6 | 
Due to the length of this program part two will be in the 


next issue. Snoopy calendar consists of two parts. Part one is. 


the calendar while part two is snoopy himself. 


UTILITY REVIEW — W.P. TAPE/DISK :- | pags ~ 

Tape W.Processor to Disk conversion utilities which uill 
allow you to convert your Tape W.P. for full disk use and will 
also transfer your tape W.P. files to disk. | | 


MERGING W. PROCESSOR FILES (TAPE OR DISK) :- mE | Page T ۱ 
A brief "+8 یی‎ ۶ on the procedure. The insruction book 
only mentions that it’s possible using the LOAD command. 


INTRODUCTION TO PROGRAMMING BY B. KITCH :- 0" و9٤0‎ 


This is the second informative part and contains a lot of 
good advice on how to become a competent programmer. © 
Unfotunately a lot of people skip over many articles in 
preference to more attractive material in magazines. As Bob 
mentions it’s very important to plan your program if you want to 
improve your skills. T ME AE 


OTHER VZ PUBLICATIONS :- © Page 10 

Ther are two other VZ publications besides ours. VZ USER is 
on the advanced side while LE’VZ 200/300 OOP is more general in 
9 Both are informative and exellent 00 0 


TECHNICAL REPORT 1 by Joe Leon :- o Pages 11- 12 
| The project shows how to fit a write protect override ‘switch, 


J change the dull motor on led to a super bright one and a power 


on/off switch to 22 disk drive. 


RESTORE BY D. MITCHELL :- ` Pages 13-15 
This is a handy utility that will RESTORE your progam “after 
using the NEW command. May also work after Using reset button. 
HIGH GAMES SCORE :- |. Page 15 


Not much activity in this area but should see some new champs 
after the School holidavs. 


TECHNICAL REPORT 2 by Joe Leon :- Pages 16-17 


Two circuits are shoun for an electronic Shift lock key. 


UNDERSTANDING YOUR VZ by Robert Quinn :- Pages 18-20 
This is the final in the series and hopefully not the last we 

hear from Robert. Quite a few people should understand their 

VZ'S a lot better now. Much ۷ Robert. | 


BYTE BACK :- 
IT appears our 00 have more bark than byte as nobody bit 
back. as 2 This section is for your comments or 0 Ss 


RELIEVE IT OR NOT :- | ۲ 

A 15 year old got a COMMODORE for وج وہ تمہت‎ it 
all up, turned on the power and a READY message appeared on the. 
screen. So he typed in YES and the latest news is he’s still 


Waiting. Things like that dont happen with the VZ, or do they ? 


Vx 


d 


== 


+22 


19 
26 


^ t 
A Tere 


HO 


LS 


20 


27 
MO 


1A 
20 


27 
MU 


Lo 
19 


TUR 


1 
Pod اس‎ 


20 


te 


XXIX 
Y LT 
Y kk X 


Y oves 
ا‎ 


P 
j 


OY wey‏ جي و 

i XXX rrkrik $ 1 > AMAN : 
yy [D ERRE heo 

Y pr OY 


j^^ 


y 
A 


XX 


Y 
1000007 


XXXX 


XX 


hires 2 
ہن‎ ۱ 
i Á X 
1 1 Y y o & 
1 UY e. Y Y i 
Y رہ‎ 3^ “y Y Y 
A ý "E i NEES ZA 
1 ؟‎ 2*5 5 2X Y 
LM . "رر‎ YYYXYYY/ y^ 
“eyyy ٦۶۹ ۶ ۹ ? ere 282123 ; ap ed Y 
CXYXYYYXXXXXXYXXYA * *, yh y^ 
EXXXXXXI T ct yey 
m x ox CYXYL Y (QE 
Lut Ue او‎ 
4- +4 RAR 
*- L4 Sie 
y- xi Ay 7 
$- 5 Y | 
e EE Y 
x H 2Y Ny 
کے‎ E ark YS AAR 
+ x fee Ly f 
x gx Yee Y X 
سے‎ xx My AX ay 7 Y 
* +4 a ak XY $4 
tt X4XyXt y à 
I-——--- ERE FF # ROO 
$ x i nux AAA, 
axl X X E ا‎ Y | 
samt £ 
mame reer EEE a A- Ae نے‎ S 


mn m çaw onm ona aaa NEP ume P HED FDO ONIS جات‎ CENA Ense S OTD مکوم ہمد‎ SOND eve jv ane a OTD D mem 
gue amm Mea uas کید بوھصہد مھ‎ O ہی حور‎ Mum hme PU cua میمہ‎ Rupe بم مج‎ CN فاص‎ arit. Pars rase Cane نشم بسر ممت هبت جم‎ caer 


emus anu کو بے مروں‎ ADO ¿O OSD دہ‎ HUI OUI). AMA موق‎ GM GOED uM OMM) OED MA WAND MO QD. VO Cif» SUT «eU UMP MD VU Ohi QUID aD SUING SLED VP OO omo 
مم می‎ 9 O AM au عمد مسد‎ nhe ڈور دد و ڈولوہ جوم‎ EN مم ندم‎ mam cup وف‎ ES NEE ON qp جلو مو‎ MO ہےوہ‎ Ue بین وم‎ chm ہمہ‎ uum موہ‎ ane سے‎ 


JANUARY 
TU WE TH 
| 1 
6 7 8 
13 14.15 


21 22 


27 28 29 
APRIL 

TU WE 
1 2 

7 8 9 

14 15 


14 
21 22 23 


29 30 


<a 


JULY 


TU WE TH 


] 2 


C6 um y 
14 15 16 


23 caer 723 
A سگ سک‎ X گے‎ 
AO 


Ad 29 


OCTOBER 

TU HE TH 
Ja 

6 7 8 


13 14 15 
Dip a 
27 28 29 


I FH 


rs 07‏ و 
uo 24‏ 
ORNA‏ 
AQ 31‏ 


10 
17 


24 25 
FR SA 
3 a 


10 
17 


24 25 


A1 
FR í 


14 


ZA ZA 


0 


tr) 


RJ UL Oo ee E 


MJ سم‎ 


du |‏ وو تر ری 7 
PNY‏ 


Mo 


1i 


18 


TEL 
aad 


GMO PY CALENDAR EY D. BOYCE = .- 


amu artes AS MIA evan DADOS سک چومں‎ sono Arad GOED QUT. 09 HD UND GUND STD e QUUM (MD اہ‎ GENS (dtp. QUA QUIA CEN MERO IUD AGO SEND SND AND کول‎ OED ط٥‎ GAD فئال‎ Cove suum Sows 
e e cara ہہ بویت جات جیه مور متو‎ SAAN tm O OA مر‎ vedi کالہ‎ tais می‎ ENDS می‎ tape سس‎ UDI یہ‎ muet um س بیت ممت‎ MD HUND aata A Mahe AONE حلص‎ Gu Gants e عمومہ‎ Nee 


FEBRUARY 


TU WE TH 
3 4 5 
10 11 12 
17 18 19 


24 25 26 


MAY 


TU WE TH 


å 7‏ کے 
14 13 12 
21 20 19 
28 27 25 


AUGUST 
TU WE TH 


4 3 € 
1l 12 15 
19 20 
lp 26 27 


NOVEMBER 


TU HE TH 
3 4 5 
10 11 2 
17 18 19 
24 25 26 


FR 


13 
Lo 


"2 
a 


FR 


13 


gari 
aL aL 


Erts 
Aa $ 


FR 


14 
ud 


28 


FR 


1s 
20 


ER 


A È 


14 
2i 


20 


sá 


18 
273 


A 


Ga 


14 
٦ 


28 


Su 


14 


xi 


^ 


A 


su 


PJ BJ ma 
“J OD CU 


eee eee eee e e Rn n E n rmac‏ مە عست بجی وت ەە 
eee queo uam o en‏ زج salo MED GPS‏ ممم میس موم وید e LTE n re UP‏ 76ہ حسم uic dades ditus eee e‏ سی معب tee‏ لہ بمج سیم ماش ممع 


TH 


2 3 4 85 
9 10 11 12 
17 18 19 


23 24 23 26 


30 
JUNE 
MO TU WE TH 
1.2 3 4 
10 11 


13 16 17 18 


| 24 25 
29 30 | 

SEPTEMBER 
MD TU WE TH 


1 2 


7 80 9 10 
14 15 16 17 
21 22 23 24 
2H 


29 XO 
DECEMBER 
TU WE TH 
001 2 à 
7 B 9 10 


MO 


14 15 14 17 
2i 22 253 24 
¿8 29 20 31 


1 
= 


27 


FR 


12 
19 
26 


FR 


14 
18 


n= 
a 


FR 


11 
18 


mE 


a wel 


SA 


14 


2p e 


-2 
a 


SA 


33o 


20 
27 


98 

12 
17 
26 


SA 


12 


19 
26 


SNOOFY CALENDAR CONT. 2 2 2 ہے‎ 


ao '  SNOOPY CALENDAR FOR THE 
100 ° BROTHER M-1009 OR EQUIV. 

110 °’ DOT MATRIX PRINTER. 

120 ° FILE - SNOOPYCL | 

130 CLS:PRINT:PRINT"DO YOU HAVE YOUR PRINTER" 
135 INPUT" TURNED ON «Y/N»";DF$ _ 

140 IF DF$-"Y" THEN 155 


145 PRINT:PRINT" OH WELL !! - SWITCH OFF AND COME BACK. WHEN"; 
150 PRINT" YOU HAVE - BYE! !": END | : | E 
155 CLEAR800 | | 

ا سس سے سے سے سن سے سے سے سے سے سے سے سے سے سے سے سے سے سے سے سے سے ہے سے سے سے سے ہس سے سے ۱۲ ۔- ١778‏ 162 


165 DIM L(11),YR(11,6,4),X$(9,9) 
170 DATA 31,28, 31,30, 31,30, 31,31, 30,31, 30,31 | E» 
172 *---X-------- X-X-------- X-X------- dO A E X 


175 DATA" 000000 ", "00000000", "OO . OO", FOO 00". TOO. + 00" 
180 DATA"OO O00", "O00 OO","OO | 00","00000000"," 000000 " 
185 DATA" 41 bd 11 AR. 111 UM 11 CUI ٤ n. 
190 DATA" 11 Eu i 11 ges 13 ا‎ 41010110 "Coe 0117ء‎ 
195 DATA" 222222 ", "22222222" "22 EA Zag BAAD 
200 DATA” 222229 ", "2292 M e . 0 ۰. 
(205 DATA"33333333","33333333"," | deb c debe Est 3393. + 

. 210 DATA" C cio do uno 33", "33333333"," 333333 " 
215 DATA" A nos AA "e AAA El 4444 JE 44 44 " 
220 DATA"44 44 ","A4444444","44444444", " 44 — 0." 44 " 
225 DATA"55555555", "55555555", "55 SS ۳۹۰9 ~ 
230 7۸ھ104‎ "55555555" " SSN" ES: 4 9t 5655555551," 555595 * 
235 DATA" 686666 ", "66666666", "66 66", "66 ", "6666666 " 
240 DATA"66666666", "66 66 6 66", "66666666"," 666666 " 
246 DATA TITTIT ET 5 رو رای رر رپ‎ ke age "OE Ar Sal ATE Mes, 
250 DATA" 77 ا‎ TT ۴2ا 77 ۱ ا‎ 27 ME, 77 a 
200 DATA” 6388889 ^7," 88055889", 8 88 GO 98^". 888880 " 
260 DATA" 888888 ", "88 088 EB 88", "88888388", " 888888 " 
265 DATA" "999999 "," S99ggogg", 99g +8 99", "99999999" . 
270 DATA" 9999999", " gg. "99 dor "99999999; "999999 -7 


Lla سج ہر‎ ae KSA a hehe a kaha See X-X-------- X 
275 FOR I=0 TO 11:READ L(IO:NEXT I | u | n 
280 FOR IzOTO 9:FOR J=OTO 9:READ X$(I,J):NEXT J:NEXT I 
ZONY. ? | | e 
290 GOTO 440 
. 295 FOR M=O0TO 11 
298 PRINT"."; 
300 WzO:DT-1 
305 YR(M,D,W)=DT:DT=DT+1:DP=D+1 : 
310 IF D>6 THEN D-O:W-W-1:IF W>4 THEN W=0 
315 IF DT<L(M)+1 THEN 305 
320 NEXT M:SOUND1, 1 
325 RETURN | | | 
330 QO$=RIGHTS(STR$S(Y),4):11=VAL(MIDS(Q$, 1, 1)) 
335 12=VAL(MIDS(08,2,1)):13=VAL(MIDS(Q08,3,1)) 
340 TI4=VAL(MIDS(08,4,1)) | 
345 LPRINT:LPRINT | 


348 LPRINT TAB(25);" .  "5VZ$;VZS$:LPRINT. 
350 FOR I-0TO 9 | | | 
3852 *--X------------------X---------- X-----X--------- X 
355 B$=" 7 "K$(11,1)4" "4X$(12,1) 
360 BS=BS+" "+X8(13, 134" "+X$(14,1) 

| 365 LPRINT TAB(25):B$ — | E 
370 NEXT I 


375 LPRINT:LPRINT TAB(25) 3" "SVZS;VZS:LPRINT CHES( 18) 
380 RETURN | | | ! 


Ny 


SNOOPY CALENDAR CONT. So o e 
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LPRINT AS | 

FOR W-zOTO 4:B$="" 27 

FOR I=0TO 2:B$- Bsr" ls 

FOR J=0TO 6 | "OPE 
IF YR(M+1,J,WN)=0 THEN C=" " ELSE CS=STRS(YR(M+1,J3,W)) 

IF LEN(C$)«3 THEN C$-" "+C$ _ 

B$-B$4C3$ | 

NEXT J:NEXT I 

LPRINT B$ 

NEXT W | | 

LPRINT: RETURN | | 

CLS:PRINTTAB(6)" VZ 200 CALENDAR": PRINT 

PRINT" THIS PROGRAM WILL GENERATE A CALENDAR FOR ANY ii 


PRINT"YEAR IN THE RANGE 1901 - 1999. ALL YOU HAVE TO " 
PRINT"DO IS SPECIFY THE YEAR!" | 

A$=" SU MO TU WE TH FR SA":A$=AS+AS+AS 

pon eee X-X--->---X-X------------------X---------- X‏ ھا 
JANUARY "+" , 6 "4+" FEBRUARY"‏ "4" ہے Hi$="‏ 
H1$-H1$4" ` "+"MARCH" o‏ 
H2$z'" . "+" APRIL +" $ u‏ 

H2$-H2$4 "MAY "+" s "4" JUNE" | | 
H3$-—"! hh JULY "+" : | "+" AUGUST li m 
H3$-H3$4" (— "+"SEPTENBER " | | | 
HA$-". : "+ "OCTOBER" +" — ` n4 "NOVEMBER" 
H4$=H4$+" — | "4 "DECEMBER" ا‎ 

be Ei 0۳ - 7 .سیت‎ 
SOUND1, 1 SS TE 
INPUT" FOR WHICH YEAR WOULD YOU LIKE A CALENDAR ";Y 

PRINT" PLEASE WAIT -- I'M INITIALISING MY DATA..... "o 


IF Y«1901 OR Y>1999 THEN PRINT:PRINT"OUT OF RANGE": GOTO 505 
IF 4xINT(Y/4)=Y THEN L(1)=29 | ۱ | 
I=Y-1901:J=INT(1/4):+1=1-4xJ+2 


K=5x(J-T7XINT(JI/7))4+1:D=K-7xINT(K/7) 

GOSUB 295 | 7 
SOUND 3,3:PRINT: INPUT"PRESS «RETURN» WHEN READY zea TT 
PRINT" PLEASE WAIT ... I WILL NOW" 

PRINT" PRINT-OUT YOUR CALENDAR FOR" 

PRINT" THE YEAR-:"3Y | 

GOSUB 820'TO SNOOPY ROUTINE E 


GOSUB 330 . 
LPRINT CHR$(27)4"2" 

M-O:LPRINT H1$:GOSUB 385 

M-3:LPRINT H2$:GOSUB 385 

M=6:LPRINT H3$:GOSUB 385 

M-9:LPRINT H4$:GOSUB 385 

CLS:LPRINT | | | B | 
INPUT"ANOTHER YEAR ";YY$:IF YY$-"Y" THEN RUN ELSE 590 
LPRINT CHR$(27);"à" | | | Zu 
CLEAR 50:CLS:PRINT"BYE-BYE":FOR LL-1TO 10:LPRINT:NEXT LL 


END 

LPRINT CHR$(27):"3";CHR$(vVI8); ° LINES 18/216 APART 
LPRINT CHR$(15):; 'CONDENSED | ! 
LPRINT:RETURN mE 


1500 ERA"SNOOPYCL" 
1600 SAVE"SNOOPYCL":CLS:DIR 


LET ER XT Y REVIEW — We. TAPE,‘ DISK 7 


Although the VZ has been around for several years, the 
better type utilities have been few and far between. The VZ tape 
Word Processor falls in this category, but unfortunately cannot 
be used with Disk. That used to be the case till Dave Mitchell 
of Rockhampton, Queensland did something about it. The result | 
is that with p. Mitchell's two utilities you can convert your 
Tape W. Processor for full Disk use or Tape LOAD, Disk SAVE. 


Utility one سی‎ This will convert your Tape W. Processor 
for full DISK use. It will SAVE, LOAD and give DIRectories of 
your Disks. Needless ta say, it loads/saves much faster than 
tape and you can see what files you have on Disk. The amount of 
free Disk space is alsa shown. One other built in feature is the 
ability to protect sensitive files from unautorised perusal by 
making them invisible to the d LE command. 


Utility two :- This simply converts your Tape W. Processor 


for Tape LOAD, Disk SAVE. IT allows you to transfer your Tape 


W. Processor files to Disk to be used with previous converted 
full Disk version of W. Processor. | 


Both versions require a VZ 200/300 With 16K Ram Expansion. 


Fortunately for H.V. VZ Users’ Group D. Mitchell has donated 
the above conversion utilities as a fund raiser for H.V. VZ 
Users’ Group. The club owes him its’ gratitude. Thanks Dave. 


The two utilities are available from H.V. VZ Users’ Group for 
$10.00 and includes Disks Conversion Programs, | full 
instructions and Post and Packing anywhere in Australia. 


One thing we would like to make absolutely clear is that we 
will not supply under any circumstances D. Smiths Tape W. 
Processor. You have to purchase it from D. Smith in the usual 
WAY. All we are selling is a means to convert your Tape W. 
Processor for Disk use. | | ےڈ"‎ LX 


MERGING FILES (TAPE OR DISK) :- 


Although mentioned a couple times in the  W. Processor | 
instruction book about MERGING files it does not tell you hou to 
accomplish it. The procedure is quite straightforward. | 


Step 1 T . Before MERGING files make sure you have both files. 
saved to tape or disk. It is very easy to lose or corrupt one of 
the files. | ۱ 5 P 


otep Xe Load first file from tape or disk. Enter EDIT mode: 
and move the cursor to bottom of text. Press RETURN about 4 
times. Return to main menu. | P t or 


Step 3 :- Load second file from tape or disk and the two files 
Will be MERGED. The second file will be appended to the bottom 
of file one. | | | | | E 7 | 


Ány number of files can be MERGED up to W.P. memory capacity. 
Failure to move cursor to bottom of text will wipe out previous 
text from cursor position down. Use edit commands to rearange or 
edit your MERGED files. Like allways, test out the procedure 
till you are satisfied vou understand its operation. 


INTRODUCTION TO PROGRAMMING . . & 
Part ہے‎ by Bob Kitch. | 


As: mentioned in Part 1 of this series, the programming task .. 
is a large and complex feat of organization and requires a wide | 
range of skills. It is possible, and best, to break the task 
down into six segments - each of which must be thought about, ` 
planned and then carried out to ensure the successful completion. 
of a software project. Even a small program requires that a 
cursory consideration of the six segments be made - although some 
of them may be quickly passed over as trivial. But it is certain 
that larger programs (more than 200 lines) require careful 
planning for success. C» d E | | 
| Before describing the six Steps, it is worth thinking about 
"What makes a GOOD program?" BE | T 

A program may be judged from a number of different. 
standpoints; each iS not necessarily mutually exclusive and 
sometimes some conflicts require that a trade-off be made. 


The first criteria is that a program should be EFFICIENT. 
Efficiency can be considered from a number of varying view 
points. For example, optimization of the run-time can be 
considered as efficient. Also, reduction in storage requirements 
for both program code and variables can be considered as 
efficient programming. Furthermore, and particularly if one is 
developing software commercially, then efficiency can be 
measured in terms of the actual time required to get an 
applications program running and the ease of maintenance of that 


code. The use of appropriate data types and data structures can. 
greatly improve the efficiency of a program. The selection of a 
suitable algorithm can also assist. Finally, ease of debugging 


so that the program can be updated or modified may be considered 


desirable. 


The second criteria is GENERALITY and it is here perhaps that 
so many programs "score" so poorly. Rather than a program being. 


written to solve a particular chore, it should be broadly 

written to handle a wide range of problems. The use of 

subroutines and functions developed and debugged previously can | 
 enormously improve programming productivity. Often a simple. 


substitution of a variable for a constant in a program can 
broaden the the applicability of the program 003ۂ00ھ ھ00‎ 0 


The final criteria is ELEGANCE, which is a little harder. to 
both define and achieve. An elegant program is one that is 
Simple and ingenious, and possibly uses an algorithm or data 
Structure that may not be "0 - ۳ obvious to the application. 

The so-called "programmer’s tricks" are often elegant solutions. 
to a programming problem; but beware, some are +00 جو‎ 
programmers to conceal their programming stategy. | 


| These then, are general guidelines to try and attain in your 
programming and by which to judge a particular programming effort 


as good, mediocre or poor. Notice that they are not language © 


specific comments and are equally applicable to any 00 9 ۴ 
language or exercise. 

To return to the six steps in the programming task = 1 will 
briefly discuss each in turn and ask that you consider each one 
when embarking upon your next programming exercise. Also as one 
proceeds through the steps, it is often necessary to recycle 
back through some of the preceeding steps, to iteratively 
improve the exercise and your understanding of ideas. | ۱ 


42 


INTRODUCTION TO PROG GRAMMING . ۔‎ $ 


1, PROJECT SELECTION. This may appear trivial, but we all 
have too many ideas for programs and rarely know uhich one to 
tackle next. Also be honest with yourself: some of the projects 
are probably too ambitious for your existing skills and an 
attempt upon these will possibly result in frustration and 


perhaps failure. Choose an exercise that is challenging and 
worthwhile. Try not to "reinvent the wheel", try to be aware 
through reading magazines or discussing with other Users what 
programs are already available. Modifying an existing program to 
suit your specifications is sometimes quicker - it also allous. 


you to study how other programmers tackle problems.  O.K., so 
now you have an idea or problem that you wish to tackle and 
solve. | | | | ۱ | 
2. PROJECT FEASIBILITY. Again be honest. Do you have the 
hardware, software and know-how to achieve the result? Its is 
not really much use trying to write large business-oriented data 
base programs for an 8K tape-based VZ! Check that the task is 
reasonable. | | | S | 
3. PROJECT DEFINITION. This is where the idea starts to get 


translated into a reality. It is also the phase uhere generality 
can be written in. It is easiest to start by thinking about the 
input to the program. Is it keyboard oriented, or is it to come 


from a programmble I/O port? Perhaps the program reads only DATA 
statments to configure itself or maybe the program must check if 
a printer is connected to the sytem? Start defining what the 
input will look like. Assign variable names with meaningful 
mnemonic names at this stage also. | | 

Next, define the output expected from the. program. Is it to 
write to tape and in what format? Perhaps it is to be screen 
oriented - can sound be used - or perhaps voice synthesis to tell 
the operator uhat is going on? Plan very carefully and fully the 
layout of the expected output as this is how Users will BR 
perceive the quality of the program. 

After defining the I/O for the program we Should nou have a 
feel for the anticipated range of parameters that the program is 


meant to accept and also handle. This brings in the very 
important concept of defining the BOUNDS Within which the program 
must function correctly. Following on from this, is range 


Checking of all input parameters so that the program cannot goa 
beyond the range that it was designed for and give unexpected 


results. A number of warning messages must be built into the 
program along with error capture and recovery routines. It is ہ‎ 
failure to define the operating bounds of a program that causes . 
most crashes or rogue behaviour. Even the definition of integer 


variables at this stage can assist by improving Prog ۵ execution 
time and reducing storage requirements. | | 
The definition stage should be roughed out on pieces of paper 


kept for later reference. Perhaps better, is to use an old. 
exercise book. Another benefit of this is that over a period of 
months your progress can be measured and your growth of. 
programming ideas recorded. Another benefit (although I hardly 


dare mention it!) is that if, after the coding stage, a system 
crash occurs and you didn’t SAVE the program, then ail is not 
lost — at least an outline of ike program remains. | 
4. DESIGN PHASE. Having sorted out I/O and operating کھت‎ 
the . actual. selection of an algorithm to achieve the result is 
commenced. By this time some idea of the number of variables 
required and their type should have begun to gel. This is also 
the stage where your basic honesty in stages 1 and 2 may catch up 
With you! Data structure organisation and algorithm selection are 
really experience-related skills. | | 


ef 
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Hence the suggestion to read and/or modify existing programs. 
But do not despair - practice makes perfect. | | 


5. IMPLEMENTATION PHASE. To date very little actual coding 
Should have been done; in fact the computer need not even have 
been turned on! Some people may be surprised at hou late in the 
task the computer actually enters into the picture. An awful 
lot of planning and organizing can be done off the computer and 
on the "backs of old envelopes". 

It is also at this stage that the choice OÍ ori 
language should be made. Is the program time dependant? If it 
is, then it should probably be written is Assembler. If the 
actual timing is not so critical then writing in BASIC with its 
diagnostics and helpful features (so typical of a high level 
language) deem it sensible. Experienced programmers will 
probably use a bit of each in practice. A very sensible 
compromise is to develop the program in interpreted BASIC and 
once finalized and debugged, compile the BASIC code to speed up. 
execution. | | | | i | m 

6. EVALUATION PHASE. This is the moment of truth! Does the 
program fulfill all the criteria set out in the definition phase. 

If. so, then you have succesfully achieved your task. Is the 


output as you expected it? Are the results correct? It is a 
good idea to have a standard set of data to exercise the program . 


so that it can be quickly verified after a program alteration. 


Ensure that all logical paths through the program have been 


exercised so that no spurious errors of logic remain undetected. 
Finally, | deliberately try values that are out of the intended 
bounds of the program to ensure that you have trapped them and 
that the program recovers from this type of misuse above and 
beyond its? intended design range. E : 


As mentioned in part 1, the offer on programming queries. 
Still stands. If writing to Bob Kitch please include a SAE. 


BOB KITCH | | (07) 378 3745 
7 EURELLA STREET | 
KENMORE 4069 

QUEENSLAND 
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MARK HARWOOD E | J.C.E. D'ALTON 
P.O. BOX 154 | E 39 AGNES STreet 
DURAL 2158 | | TOOWONG 4066 


N.S.W. | m | . QUEENSLAND 
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| WRITE PROTECT OVERRIDE SWITCH سی‎  — By Joe Lean 


This is to my knowledge the first hardware modification for 


p | the VZ Disk Drive. As most of. you may be aware it is possible to 
| use the reverse side of your Disks for program Storage simply by 


Cutting. a matching notch on the opposite side of the Disk. 


.. Commercial Notchers are available for that purpose or you can use 
|... scissors if care is taken. And now to the circuit. 


Only the circuit within the box is needed. The rest is part 


"^ of the disk. drive circuitry and is shown so we can understand 
. what is happening. When a notched disk is inserted in the drive 
oc a small light. shines through the notch on the disk and 
= illuminates. the photo transistor (STR1). This has the effect of 
= grounding pin 13 `of U3. When that happens the disk can be 
Written to. ` If you have a Write Protect Tag covering the notch 


then a ‘DISK WRITE PROTECTED’ message apears if you try to write 


cor tor the diske. s 


It follows. then that to overcome the urite protect function 
we must ground pin 13 of U3. The easiest way to ground pin 13 of 


US: ds. to connect a wire to the 4K7 resistor and the other end to 
oo. the switch as shown in the diagram. I used a Flashing Red Led as 
.  & Warning for which no resistor is required if used uith 5 Volts. 


(. If you have trouble getting a flashing red led from D. omiths 


try TANDY’S. This is a Simple project that should’nt present an^ 
Problems. Only the top cover of the disk drive need be removed 
and. just. follow the diagrams. Once installed the switch will 
‘ allow you to write to the flip Side of disks without notching or 
7. over a write protect tag on the front Side. Exercise care uhen 
using the WRITE  PROTECT OVERRIDE SWITCH as your disks are no 


While you have the cover Off there are tuo more modifications 


|. you. can try. When the VZ is accessing the drive you only get a 
vo duli “red: glow from the motor on led. It can be easily replaced 
© by a super bright 5mm LED. The easiest way to do it uithout 
. removing the circuit board is to cut the pins of the old led as 
| . close to the body of the led as you can. Then place the super 
. bright led over the old pins and push it towards the front till 
co it nearly touches the rectangular lens and solder in place. Use 
|. caution and a heatsink when soldering the led as they are heat 
,. Sensitive. Make Sure the led goes in the right way. The 
.^" negative side usually has a flat side on the body. See circuit 
“oy diagram. oo. =e ratu | 3 : | | | 


- POWER ON/OFF SWITCH :- 


Again this is a Simple project. Just a switch and a led with‏ | وم 
dropping resistor is required. Or you can dispense With the‏ 


SWitch and just use the led with its resistor. Again it's up to 


. you where the components are mounted. 


If. your drive is still under warranty then any modifications 


“will void- it. Dont forget the responsibility is yours for any 
mishaps. If you doubt your ability to carry out the 
modifications thendont. | RM TE? 
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. WRITE PROTECT OVERRIDE SWITCH :- 


By Jos Leon 
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YOU PEESSED NEW INSTEAD OF RUN 


DON'T WORRY :—- . When you use the NEW command 
| | | the VZ POKES TWO ZERO BYTES | 
into the start of the basic program 
to replace these bytes is very easy 
What they tell the computer is 
the address of the next line of 
the basic program. 


TRY THIS :- Type in line 10 then return 


Type in line 20 then return 


10 CLS 
20 PRINT 


WITH NO LINE NUMBER TYPE & press return 


FOR I = 31465 to 31476 : PRINT I ; PEEK( i ): NEXT: 


LISTED ON THE VIDEO SHOULD BE 


31465 239 ; ADDRESS OF THE NEXT LINE (LSB) 
31466 122 ; ADDRESS OF THE NEXT LINE (MSB) 
31467 10 ; LINE NUMBER (LSB) © 

31468 0 ; LINE NUMBER (MSB) 

31469 132 ; TOKEN FOR CLS 
31470 O ; END OF LINE | 
31471 245 ; ADDRESS OF NEXT LINE (LSB) 
31472 122 : ADDRESS OF NEXT LINE (MSB) 
31473 20 ; LINE NUMBER (LSB) 
31474 © ; LINE NUMBER (MSB) 
31475 178 ; TOKEN FOR PRINT 
31476 o ; END OF LINE 


31465 8 31466 contains the address of the next line. WITH simple 
maths it is easy to find this address :- | | | 
239 + 256 * 122 = 31471 


CHECK 31471 YOU WILL SEE IT IS THE ADDRESS OF THE NEXT Line. | 


List the program you typed. Now press NEW & return. 


List again, WHAT DID YOU GET ? WAS IT NOTHING ? 


TYPE :- PRINT PEEK( 31465 ) 3 PEEK( 31466 ) & press return. 
IT SHOULD BE --- 0 چ۵‎ | a ! "EE | 
TYPE :- POKE 31465,239 : POKE 31486, 122 : LIST 8: press return 


You have just got the program back from the UNKNOWN ! 


Here is an example in basic of what the machine code does. 


31467 P 

PEEK( A ) 

30 IF B <> O THEN A=A+1 : GOTO 20 
40 IF B = O THEN A=A+1 

50 C-A-(258XINT(A/256) 

60 D-INT(A/258). 

70 POKE 31465,C 

80 POKE 31466,D 


ESTORE EY DAVE MITCHELL . a 2 d: o 


RESTORE CONT. = č s - 2 = 2 «= = i14 


In line 10 'A' equals the normal start of the basic program plus © 
two. s | | 

Line 20 'B!' looks at what is at ETTET A? 

Line 30 checks if 'B' is bigger or smaller than zero and adds. one 
to 'A' then goes to line 20 

Line 40 checks if 'B' equals zero then *A”? is added Wi theme is 
zero inicates the end of the basic line.) | ZEN 
Line 50 works out the LEAST SIGNIFICIANT BYTE (LSB). 

Line 60 works out the MOST SIGNIFICIANT BYTE. | 

Line 70 POKES 31465 with the LSB. | 

Line 80 POKES 31466 with the 07 


The above program is only an EÊ tO help you understand | 
the assembler code later. | 


FOR THOSE WITHOUT AN ASSEMBLER PROGRAM. 


10 FOR I = -20480 TO -20391 

20 READ A:POKE I,A: NEXT 

 30DATA205,201,1,33,39,176,205, 167, 40, 17,236, 122,19, 26, 254, 0,32 
40DATA250, 19,235, 34, 233, 122,33,233, 122,34, 164, 120,205, 248, 26,35 
SODATAS4, 249, 120, 195,25, 26, 13, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 92. 
GODATA82,69,83,84,79,82,69, 13, 13,32,32, 32,32, 32,66, 89, 32,68,46 
TODATAT?7,73,84,67, 72,69, 76, 76,32, 325065105025 15,509, 65, 0,0, 9, O 
80 CLS:PRINT"SAVE TO DISK OR TAPE (D/T)" 

90 AIS=INKEYS: AS=INKEYS: TEAS <> SDN ANDAS< > T 'IHENSO- 

100 SOUND30, 1: IFA$="T"THEN180 

110 IF PEEK( 16384 ) = 170,140 

120 PRINT"NO DISK DRIVE YOU NAUGHTY PERSON" 

130 GOTO 180 | 

140 PRINT"INSERT DISK,CLOSE DOOR & PRESS RETURN" 

150 IF INKEY$<>CHR$( 13), 150 | 

155 SOUND3O, 1 

160 BSAVE"RESTORE",BOOO, B059 


170 END | 

180 FOR I = -24576 TO -24526 © 

190 READ A: POKE I,A: NEXT ZEE | 
200 PRINT"INSERT CASSETTE, PRESS PLAY & RECORD THEN RETURN" 


210 IF INKEY$ <> CHR$(13),210 
220 SOUND30,1 

230 POKE 30862,0:POKE 30863, 160:X-USR(O) 

240 END . 

250 DATA33,0, 176,34, 164, 120,33, 89, 176, 34, 249, 120 

260 DATA33,38.160,14,241,243,205, 172, 52, 251, 33, 233, 122 
` 270 DATA34,164,120,205,248,26,35,34,249, 120 - 

` 280 DATA195,25,26,34,82,69,83,84, 79, 82, 69,34,0,0,0,0 - 


Lines 10 to 7O contains the data for restore. 
Lines 80 to 100 checks for saving to disk or tape. 


| Line 110 Checks for a disk drive. 


Lines 120 to 130 prints an error then goes to tape save. 

Lines 140 to 170 saves to disk. | 

Lines 180 to 190 sets up data for AUTO-RUN tape save. | 
Lines 200 to 210 prints message & waits for the return key to be 
pressed. 

Line 230 jumps to the machine code for AUTO- RUN 1 SAVE. 

Lines 250 to 280 data for auto-run tape save. 


FOR MULTIPLE COPIES = DISK TYPE GOTO 140 
| TAPE TYPE GOTO 200. 


ید 


+ 


RESTORE COIT. a a s o g i 175 


THE ASSEMBLEE POUR 


CALL O1C9H X iclear screen. | 

LD HL,MES ; load HL with the message menc 
CALL 28A7H sprint the message. 

LD DE,7AECH  ;load de with 7AEC hex. 

SCAN INC DE sadd one to de. | : | : 
| LD A, (DE) sload ’A’ with what is at the address of DE. 
CP OOH | ¡test — is it a zero. "C 
JR NZ,SCAN ¿NO - go back to scan & do it again. 

¿YES - continue. | 
INC DE sadd one to DE. | 
. EX DE,HL sexchange regesters. 


LD (7AE9H),HL;load the contents of HL into TAES HEX. 
LD HL,7AE9H ¿load HL with 7AEQ HEX. a 
LD (7844H),HL;3load start of program with HL. 


CALL 1AF8H £sreset program statement table. 
INC HL sadd one to HL. 
LD (78F9H),HL;load end of program with HL. 
JP 1A19H ` JUMP TO BASIC. 
MES EQU $ | ¡start of message. 
DEFB ODH ;Carriage return. 
* [11 spaces] RESTOREX © NR 
DEFB ODH carriage return. 
DEFB ODH icarriage return. 


X* [5 spaces] BY D.MITCHELL* 


* [2 spaces] VK4KDAx 
NOP send of message. 


ORGIN OBOO HEX. 
START OF PROGRAM BOOO HEX. 
END OF PROGRAM B059 HEX. 


NOTE :— PROGRAM WILL RUN IN A STANDARD VZ300 OR VZ2OO + 16K. 


HIGH GAMES SCORE ےی _ے ہے‎ 2 2 = = « 
ASTEROIDS | 0... 5... 85020. . . MATTHEW TAYLOR 
CIRCUS .. - . . . 4850... . GEOFFREY KEEN 
DAWN PATROL . . . . . 60200 . . . MATTHEW TAYLOR 
DIG OUT . .. .. .. 83700. . . GEOFFREY KEEN 
GALAXON . . . . . . . 29200 . . . MATTHEW TAYLOR 
GHOST HUNTERS . . . . 18780 . . . CHRISTIAN WARNER 
HAMBURGER SAM . . . . 83600 . . . GEOFFREY KEEN 
HOPPY . . . . . . . . . 10740 . . . MATTHEW TAYLOR. 
LADDER CHALLENGE . . . 25400 . . . MATTHEW TAYLOR 
PANIK. . o... . 16720 . . . BARRY KEEN 
PLANET PATROL . . . . 1591 . . . WARREN KEEN 

ROAD WARRIOR... . . 28370 . . . MATTHEW TAYLOR 
SPACE INVADERS . . . . 17290 . . . MATTHEW TAYLOR 


STAR BLASTER. . . . . 812 . . . ADAM MAGEE 





Co SHIFT LOCK SWITCHES to ; (By Joe Leon 


Instead of using a mechanical push on/push off switch an 


electronic FLIP FLOP can used. Two versions are shown. I’ll 
acu leave it up to you which version you use. | 


JUÉTROUIT 47:2 707 


| This circuit uses one half of a dual flip flop. This is the 


^ ene I used. The P.B. SW. (Push Button Suitch) shoun can be a 


Small momentary switch mounted anywhere convenient. In my case I 


== = used the RIGHT SHIFT KEY on the VZ 300 Keyboard. If you decide 
sie uSe this option then the track on either side of the Right 
‘Shift Key on the Keyboard P.C.B. must be cut. Solder a thin wire 
2 to each side of the KEYPAD on the track leading to the isolated 


Shift lock «switch. The other ends Of the two wires g0 ás shown 
con the circuit diagram. While you have the Keyboard apart you 

| o may decide to mount the 3mm LED as I did. It uent in the Right 
005 Shift Key Cap itself, right above the "I" in the word SHIFT. It 
^. looks neat. "The choice is yours where it goes. Connecting the 
Transistor to the keyboard matrix is straightforuard. When built 


the LED will let you know when the switch is on. If the LED is 


A. On, | but Shift Lock is not then try reversing the leads from the 
. Transistor. | | a LM 


CIRCUIT A ws 


-This circuit does the Sane job as above and is intended for 


(| Persons ‘who built the softstart switch aS shown in the November 
: :ا‎ dssue, page 8. It uses the left over gates from that circuit. 


"0۳ٍ ۶ٔ TOUS are CMOS type and special handling precautions must 
(s be observed. ^ Do not” touch the pins on the 8 aS Static can 
destroy them. Use a socket for the IC just to be safe. Also all 
7v unused INPUTS must be grounded or taken to +5V. Pinouts for both 

TOS arê shown to help intending constructors. | 





And I bought this one to explain 
the manual of the first one! 


|. GROUND PINS 8,9,10,11. 
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e 18 for LLISTing of DLINE. 


DLINE is the deluxe version of LINE. When you. have entered | 
DLINE, check the accuracy of the DATA statements with this | 
direct command: : | 


FORR-29184 TO 29260:READA:Z=Z+A:NEXT: PRINTZ 


Df your answer is not 6319, then recheck all the numbers in 
the DATA statements at the end of DLINE. When RUNSOOO,  DLINE 


Will ask for a line number. Enter the number of the program line 


you want analysed, or enter a basic word. , If you enter a word, 
DLINE will search through the word table (token list table) for 
the word and print the token code for that word, then ask for a 
line number again. ES 


When a line number has been entered, DLINE will ask fora . 
token. If you want DLINE to seek out a particular token code in 
the line, then enter that token and DLINE uill display each byte 
in the line in continuous Sequence, pausing only when it 
encounters an instance of the token. If you do not want DLINE to 
search for a particular token, then simply press «RETURN» and 
DLINE will display the first five bytes of the line and pause. 
Press «SPACE»? to single-step through the remainder of the line. 
DLINE will display the address of the memory cell for each byte 
byte in. the line (first,second,third,etc.), the byte itself, 
then the character or basic word designated by the byte (under 
the ? heading) and, finally, the negative PEEK/POKE address of 
the byte if the address is greater than 32767. Whenever DLINE 
pauses, you can press <0> or <L> or «X» key to activate a 
particular POKE facility. E | B 


EO DLINE will ask for a POKE address and then POKE the number 


140 (token code for LET) to that address. 


«L»: DLINE will ask for a POKE address, then for a as and 
POKE the token number to the address. | 


O PE DLINE. will ask Pos a TOKEN and then POKE the 0 number 
to the last 895 dis 0 ۶ on the screen. 


«8»: Pressing this key will reRUN DLINE. 
50300 IFZ-192THEN PRINT"VARPTR";:RETURN 


This line in DLINE recognises the token for VARPTR and lists 


this word when it encounters the token. Other similar lines can 
be inserted into DLINE for other words that are not functional in 
the word table. They should have line numbers greater than 50300 


and less than 50320. 
EG. D03021FZ=196THEN PRINT"STRINGS" 5 : RETURN 


Such lines should be inserted after DLINE has been merged 


with another program, because DLINE is already close to the 


maximum length of a program that can be merged using the MERGE 
routine accompanying this article. Any further lines will take 
it over the limit. Those of you who have a disk drive can run 


DLINE and then BSAVE a binary program of the machine code 
routines used by DLINE:- | | | | | 


UNDERSTANDING YOUR vz CONT. . i> 


BSAVE"LCODE", 7200, Taal and then delete all the DATA statements 
and the READ/POKE routine from DLINE.’. The memory gained can then 
be used to install a number Of Statements for 5۰ and 
8 various nonfunctional words as indicated 00 


| Line 50010 should non read: 


50010. IFPEEK (292 23) =33ANDPEEK (29224) = 233THENS0030 and a line 
50020 entered thus: | | | E 7 


50020 INPUTB:BLOAD"LCODE" 


The INPUT statement is simply a precaution to prevent you 


from initiating BLOADing of LCODE without a disk in the drive or ! 


the door closed E ve had that experience too have: you?). 

iueudentafder. iT you want to use VZ disk ےت‎ 
conditional statements, the trick is to insert a colon between 
THEN and the disk command, like this:- | X UE | | 
80 IFK=STHEN: BLOAD"PROGRAN" 


The deluxe version of line is obviously too long to type in 


every time you want to append it to a program. Salvation is at 
hand in the form of a merge routine. You need only type DLINE in 
Once, save it on tape or disk, and thenceforth use the MER 


program to join DLINE to other programs. 


MER allows you to join one program onto the end of another so 


that they become a single program. Type in MER and save. Check 
the length of MER With this length command:- | 


PRINTPEEK (30969) 4PEEK (30970) X25 6-31485 


The ansuer should be 370. Then check the machine code of. the 


MERGE routine With this command sequence: 


FORR=31273T031354: READA: B=B+A:N EXT: PRINTB 


_The answer should be 9118. If not, check out all the 
numbers in the DATA statements. When RUN, MER Sets up a machine 


code MERGE routine in the communications 0 ۸ MERGE is the 


e Which does the adding on. 


PROG 1 is the Program you wish to add on. 


PROG 2 is the program to Which you want to add PROG 1. 


The maximum length for PROG 1 is 1534 ‘yes: If you have any |. 
doubts as toa whether PROG 1 exceeds the maximum length, then . 
Check the length with the above command. . For trouble-free. 


merging, ensure that the line numbers for all the lines in PROG 1 


are greater than all the line numbers in PROG 2. 


Enter the following sequence of commands to carry out a merge 


=: (CRUN and CLOAD if you are. using a cassette recorder): 


RUN"MER" : "Transfers M. Code MERGE to communications region 


LOAD"PROG 1" *Use your name for PROG | 


PRINTUSR(8) "MERGE copies PROG 1 to video memory > 


LOAD'PROG 2" "Use your name for PROG 2 | 
PRINTUSR(8)  'MERGE adds PROG 1 onto end af PROG 2 


UNDERSTANDING YOUR OVE CONT. . BO 


Most routines you would want to merge With حر ا ات‎ program 
would be less than the maximum 270 permitted Ic 


| 0ھ ھ4"‎ should you want to add on a longer routine, you | 
can do it in stages. When you load PROG 1, chop PROG 1 in half 
by using the DELETE command (see Table X) to remove the top end 
of PROG 1, and complete the merge. Save the result; this will 
be your new PROG 2. Now repeat the merge sequence of commands 
from LOAD"PROG 1" onwards. | | | c 


v This time DELETE the bottom part of PROG 1 and merge the 
remainder with the new PROG 2 | CSS oM "A | 
Once MER has been run the MERGE routine can be used to — 


any number Of pairs of programs without having to reRUN the MER 
program each time. | 


Merge aii add on PROG 1 to PROG 2 regardless of the [ine E 
numbers of the two programs. The result could be that a routine 


is joined to the end of PROG 2 that has the same line numbers as 


|» PROG 2 or some part of PROG 2. This is an opportunity to get two 
or more programs to reside in program memory simultaneously. 
With the proper  POKEs to start of program 70+0087 you can then 
RUN the program of your Choice. 


LLISTing for MERge T 


10 FORR-31273T031354: READA: POKER, A: NEXT 

20 POKE30862,41:POKE30863, 122 

30 DATA175,42,249, 120, 17,233, 122,237,82,68, 77, 237,67,0, 114, 33 

40 DATA233, 122,17, 2,114,237, 176,33,71, 122,34, 142, 120, 201,237 

50 DATA91,249, 120,27,27,107,98,237,75,0,114,9,34,249, 120 

.80 DATA33,2,114,237,176,33,41, 122,34, 142, 120, LTOo;d0,2995122; 98 
70 DATA107, 190, 35,32,2, 1304200,35, 95,95. 190.92. 292, 39 235, 11054395 
80 DATA114,24,235 


[C] COPYRIGHT is retained by ROBERT QUINN on the series 
۸ھ‎ TENDING YOUR VZ. | o a 





